[INFO] cloning repository https://github.com/Wayazi/aperture-router
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/Wayazi/aperture-router" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FWayazi%2Faperture-router", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FWayazi%2Faperture-router'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 2f152527af2f5fad30815cc72061168d35129c7f
[INFO] testing Wayazi/aperture-router against try#b8e88e5ddf5521a9f43ee3f62a702388c713e4bb for pr-155114
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FWayazi%2Faperture-router" "/workspace/builds/worker-2-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-2-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/Wayazi/aperture-router
[INFO] finished tweaking git repo https://github.com/Wayazi/aperture-router
[INFO] tweaked toml for git repo https://github.com/Wayazi/aperture-router written to /workspace/builds/worker-2-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/Wayazi/aperture-router on toolchain b8e88e5ddf5521a9f43ee3f62a702388c713e4bb
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b8e88e5ddf5521a9f43ee3f62a702388c713e4bb" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/Wayazi/aperture-router already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b8e88e5ddf5521a9f43ee3f62a702388c713e4bb" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+b8e88e5ddf5521a9f43ee3f62a702388c713e4bb" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] fcfcf2899efea8e18e617c031a757a7054c49f1ca2fa9afbeb52e8941107ddf9
[INFO] running `Command { std: "docker" "start" "-a" "fcfcf2899efea8e18e617c031a757a7054c49f1ca2fa9afbeb52e8941107ddf9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "fcfcf2899efea8e18e617c031a757a7054c49f1ca2fa9afbeb52e8941107ddf9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "fcfcf2899efea8e18e617c031a757a7054c49f1ca2fa9afbeb52e8941107ddf9", kill_on_drop: false }`
[INFO] [stdout] fcfcf2899efea8e18e617c031a757a7054c49f1ca2fa9afbeb52e8941107ddf9
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+b8e88e5ddf5521a9f43ee3f62a702388c713e4bb" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 577312d7c1aad50e116090fefb4b51fed5f91a6f9da56c2b73326cc400461303
[INFO] running `Command { std: "docker" "start" "-a" "577312d7c1aad50e116090fefb4b51fed5f91a6f9da56c2b73326cc400461303", kill_on_drop: false }`
[INFO] [stderr]    Compiling unicode-ident v1.0.24
[INFO] [stderr]    Compiling libc v0.2.183
[INFO] [stderr]    Compiling futures-channel v0.3.32
[INFO] [stderr]    Compiling tracing-core v0.1.36
[INFO] [stderr]    Compiling http v1.4.0
[INFO] [stderr]    Compiling crunchy v0.2.4
[INFO] [stderr]    Compiling cc v1.2.57
[INFO] [stderr]    Compiling typeid v1.0.3
[INFO] [stderr]    Compiling once_cell v1.21.4
[INFO] [stderr]    Compiling pest v2.8.6
[INFO] [stderr]    Compiling sync_wrapper v1.0.2
[INFO] [stderr]    Compiling rustls v0.23.37
[INFO] [stderr]    Compiling proc-macro2 v1.0.106
[INFO] [stderr]    Compiling bitflags v2.11.0
[INFO] [stderr]    Compiling erased-serde v0.4.10
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling ryu v1.0.23
[INFO] [stderr]    Compiling winnow v1.0.0
[INFO] [stderr]    Compiling hashbrown v0.14.5
[INFO] [stderr]    Compiling tiny-keccak v2.0.2
[INFO] [stderr]    Compiling anstream v1.0.0
[INFO] [stderr]    Compiling regex-automata v0.4.14
[INFO] [stderr]    Compiling hashlink v0.10.0
[INFO] [stderr]    Compiling serde_spanned v1.1.0
[INFO] [stderr]    Compiling toml_datetime v1.1.0+spec-1.1.0
[INFO] [stderr]    Compiling quote v1.0.45
[INFO] [stderr]    Compiling clap_lex v1.1.0
[INFO] [stderr]    Compiling iri-string v0.7.11
[INFO] [stderr]    Compiling unicode-segmentation v1.13.1
[INFO] [stderr]    Compiling arraydeque v0.5.1
[INFO] [stderr]    Compiling option-ext v0.2.0
[INFO] [stderr]    Compiling tracing-log v0.2.0
[INFO] [stderr]    Compiling sharded-slab v0.1.7
[INFO] [stderr]    Compiling syn v2.0.117
[INFO] [stderr]    Compiling clap_builder v4.6.0
[INFO] [stderr]    Compiling http-body v1.0.1
[INFO] [stderr]    Compiling yaml-rust2 v0.10.4
[INFO] [stderr]    Compiling convert_case v0.6.0
[INFO] [stderr]    Compiling http-body-util v0.1.3
[INFO] [stderr]    Compiling serde-untagged v0.1.9
[INFO] [stderr]    Compiling serde_path_to_error v0.1.20
[INFO] [stderr]    Compiling thread_local v1.1.9
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]    Compiling nu-ansi-term v0.50.3
[INFO] [stderr]    Compiling getrandom v0.2.17
[INFO] [stderr]    Compiling pathdiff v0.2.3
[INFO] [stderr]    Compiling toml_parser v1.1.0+spec-1.1.0
[INFO] [stderr]    Compiling const-random-macro v0.1.16
[INFO] [stderr]    Compiling pest_meta v2.8.6
[INFO] [stderr]    Compiling errno v0.3.14
[INFO] [stderr]    Compiling socket2 v0.6.3
[INFO] [stderr]    Compiling mio v1.1.1
[INFO] [stderr]    Compiling dirs-sys v0.4.1
[INFO] [stderr]    Compiling signal-hook-registry v1.4.8
[INFO] [stderr]    Compiling const-random v0.1.18
[INFO] [stderr]    Compiling getrandom v0.4.2
[INFO] [stderr]    Compiling dlv-list v0.5.2
[INFO] [stderr]    Compiling ordered-multimap v0.7.3
[INFO] [stderr]    Compiling rust-ini v0.21.3
[INFO] [stderr]    Compiling dirs v5.0.1
[INFO] [stderr]    Compiling uuid v1.22.0
[INFO] [stderr]    Compiling toml v1.1.0+spec-1.1.0
[INFO] [stderr]    Compiling matchers v0.2.0
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling pest_generator v2.8.6
[INFO] [stderr]    Compiling zerovec-derive v0.11.2
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling tokio-macros v2.6.1
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling futures-macro v0.3.32
[INFO] [stderr]    Compiling tracing-attributes v0.1.31
[INFO] [stderr]    Compiling zeroize_derive v1.4.3
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling clap_derive v4.6.0
[INFO] [stderr]    Compiling thiserror-impl v2.0.18
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.1
[INFO] [stderr]    Compiling zeroize v1.8.2
[INFO] [stderr]    Compiling pest_derive v2.8.6
[INFO] [stderr]    Compiling rustls-pki-types v1.14.0
[INFO] [stderr]    Compiling tokio v1.50.0
[INFO] [stderr]    Compiling thiserror v2.0.18
[INFO] [stderr]    Compiling rustls-webpki v0.103.13
[INFO] [stderr]    Compiling webpki-roots v1.0.6
[INFO] [stderr]    Compiling futures-util v0.3.32
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling tracing v0.1.44
[INFO] [stderr]    Compiling yoke v0.8.1
[INFO] [stderr]    Compiling axum-core v0.5.6
[INFO] [stderr]    Compiling tracing-subscriber v0.3.23
[INFO] [stderr]    Compiling zerovec v0.11.5
[INFO] [stderr]    Compiling zerotrie v0.2.3
[INFO] [stderr]    Compiling clap v4.6.0
[INFO] [stderr]    Compiling tinystr v0.8.2
[INFO] [stderr]    Compiling potential_utf v0.1.4
[INFO] [stderr]    Compiling icu_locale_core v2.1.1
[INFO] [stderr]    Compiling icu_collections v2.1.1
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling serde_spanned v0.6.9
[INFO] [stderr]    Compiling toml_datetime v0.6.11
[INFO] [stderr]    Compiling json5 v0.4.1
[INFO] [stderr]    Compiling ron v0.12.0
[INFO] [stderr]    Compiling toml_edit v0.22.27
[INFO] [stderr]    Compiling icu_provider v2.1.1
[INFO] [stderr]    Compiling icu_properties v2.1.2
[INFO] [stderr]    Compiling icu_normalizer v2.1.1
[INFO] [stderr]    Compiling futures-executor v0.3.32
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling futures v0.3.32
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]    Compiling url v2.5.8
[INFO] [stderr]    Compiling config v0.15.22
[INFO] [stderr]    Compiling hyper v1.8.1
[INFO] [stderr]    Compiling tower v0.5.3
[INFO] [stderr]    Compiling tokio-util v0.7.18
[INFO] [stderr]    Compiling tokio-stream v0.1.18
[INFO] [stderr]    Compiling toml v0.8.23
[INFO] [stderr]    Compiling tower-http v0.6.8
[INFO] [stderr]    Compiling tokio-rustls v0.26.4
[INFO] [stderr]    Compiling hyper-util v0.1.20
[INFO] [stderr]    Compiling hyper-rustls v0.27.7
[INFO] [stderr]    Compiling axum v0.8.8
[INFO] [stderr]    Compiling reqwest v0.12.28
[INFO] [stderr]    Compiling aperture-router v0.2.2 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 15s
[INFO] running `Command { std: "docker" "inspect" "577312d7c1aad50e116090fefb4b51fed5f91a6f9da56c2b73326cc400461303", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "577312d7c1aad50e116090fefb4b51fed5f91a6f9da56c2b73326cc400461303", kill_on_drop: false }`
[INFO] [stdout] 577312d7c1aad50e116090fefb4b51fed5f91a6f9da56c2b73326cc400461303
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+b8e88e5ddf5521a9f43ee3f62a702388c713e4bb" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] b4e3d70f2cb89f74108a12756e54508f477262fbe024f4057949b4d2bf7cd08f
[INFO] running `Command { std: "docker" "start" "-a" "b4e3d70f2cb89f74108a12756e54508f477262fbe024f4057949b4d2bf7cd08f", kill_on_drop: false }`
[INFO] [stderr]    Compiling slab v0.4.12
[INFO] [stderr]    Compiling tokio v1.50.0
[INFO] [stderr]    Compiling bitflags v2.11.0
[INFO] [stderr]    Compiling aho-corasick v1.1.4
[INFO] [stderr]    Compiling mockall_derive v0.13.1
[INFO] [stderr]    Compiling predicates-core v1.0.10
[INFO] [stderr]    Compiling num_cpus v1.17.0
[INFO] [stderr]    Compiling deadpool-runtime v0.1.4
[INFO] [stderr]    Compiling termtree v0.5.1
[INFO] [stderr]    Compiling assert-json-diff v2.0.2
[INFO] [stderr]    Compiling downcast v0.11.0
[INFO] [stderr]    Compiling fragile v2.0.1
[INFO] [stderr]    Compiling ron v0.12.0
[INFO] [stderr]    Compiling rustix v1.1.4
[INFO] [stderr]    Compiling futures-util v0.3.32
[INFO] [stderr]    Compiling predicates v3.1.4
[INFO] [stderr]    Compiling predicates-tree v1.0.13
[INFO] [stderr]    Compiling regex-automata v0.4.14
[INFO] [stderr]    Compiling config v0.15.22
[INFO] [stderr]    Compiling tempfile v3.27.0
[INFO] [stderr]    Compiling mockall v0.13.1
[INFO] [stderr]    Compiling matchers v0.2.0
[INFO] [stderr]    Compiling regex v1.12.3
[INFO] [stderr]    Compiling tracing-subscriber v0.3.23
[INFO] [stderr]    Compiling futures-executor v0.3.32
[INFO] [stderr]    Compiling futures v0.3.32
[INFO] [stderr]    Compiling tokio-util v0.7.18
[INFO] [stderr]    Compiling tower v0.5.3
[INFO] [stderr]    Compiling tokio-rustls v0.26.4
[INFO] [stderr]    Compiling tokio-stream v0.1.18
[INFO] [stderr]    Compiling deadpool v0.12.3
[INFO] [stderr]    Compiling tower-http v0.6.8
[INFO] [stderr]    Compiling tokio-test v0.4.5
[INFO] [stderr]    Compiling h2 v0.4.13
[INFO] [stderr]    Compiling hyper v1.8.1
[INFO] [stderr]    Compiling hyper-util v0.1.20
[INFO] [stderr]    Compiling hyper-rustls v0.27.7
[INFO] [stderr]    Compiling axum v0.8.8
[INFO] [stderr]    Compiling wiremock v0.6.5
[INFO] [stderr]    Compiling reqwest v0.12.28
[INFO] [stderr]    Compiling aperture-router v0.2.2 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 1m 06s
[INFO] running `Command { std: "docker" "inspect" "b4e3d70f2cb89f74108a12756e54508f477262fbe024f4057949b4d2bf7cd08f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b4e3d70f2cb89f74108a12756e54508f477262fbe024f4057949b4d2bf7cd08f", kill_on_drop: false }`
[INFO] [stdout] b4e3d70f2cb89f74108a12756e54508f477262fbe024f4057949b4d2bf7cd08f
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+b8e88e5ddf5521a9f43ee3f62a702388c713e4bb" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 7c60510b637b26f35e4f54daa872af53c07a4a6318fb8b091a3ded5be9f6cdb9
[INFO] running `Command { std: "docker" "start" "-a" "7c60510b637b26f35e4f54daa872af53c07a4a6318fb8b091a3ded5be9f6cdb9", kill_on_drop: false }`
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.48s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/aperture_router-e00cfd885404d757)
[INFO] [stdout] 
[INFO] [stdout] running 58 tests
[INFO] [stdout] test cli::security::tests::test_secret_string_display ... ok
[INFO] [stdout] test cli::security::tests::test_validate_api_key_too_short ... ok
[INFO] [stdout] test cli::security::tests::test_validate_api_key_placeholder ... ok
[INFO] [stdout] test cli::security::tests::test_validate_api_key_valid ... ok
[INFO] [stdout] test cli::security::tests::test_secret_string_debug ... ok
[INFO] [stdout] test cli::security::tests::test_validate_url_invalid_scheme ... ok
[INFO] [stdout] test cli::security::tests::test_clean_url ... ok
[INFO] [stdout] test cli::security::tests::test_validate_url_trims_whitespace ... ok
[INFO] [stdout] test cli::security::tests::test_validate_url_valid ... ok
[INFO] [stdout] test cli::security::tests::test_validate_url_blocked ... ok
[INFO] [stdout] test cli::openclaw_export::tests::test_openclaw_fallback_when_no_models ... ok
[INFO] [stdout] test config::tests::test_default_functions ... ok
[INFO] [stdout] test config::tests::test_config_provider_validation_empty_models ... ok
[INFO] [stdout] test config::tests::test_endpoint_style_default ... ok
[INFO] [stdout] test cli::openclaw_export::tests::test_openclaw_config_creation ... ok
[INFO] [stdout] test cli::opencode_export::tests::test_opencode_config_creation ... ok
[INFO] [stdout] test config::tests::test_provider_config ... ok
[INFO] [stdout] test http_client::tests::test_allowed_endpoints ... ok
[INFO] [stdout] test config::tests::test_endpoint_style_deserialization ... ok
[INFO] [stdout] test config::tests::test_config_provider_validation_duplicate_names ... ok
[INFO] [stdout] test config::tests::test_endpoint_style_serialization ... ok
[INFO] [stdout] test cli::opencode_export::tests::test_opencode_json_export ... ok
[INFO] [stdout] test cli::openclaw_export::tests::test_openclaw_merge_sets_agents_if_missing ... ok
[INFO] [stdout] test cli::openclaw_export::tests::test_openclaw_json_export ... ok
[INFO] [stdout] test cli::openclaw_export::tests::test_openclaw_merge_preserves_existing ... ok
[INFO] [stdout] test middleware::auth::tests::test_duration_creation ... ok
[INFO] [stdout] test middleware::auth::tests::test_ip_parsing ... ok
[INFO] [stdout] test provider::registry::tests::test_build_endpoint_url_openai_v1 ... ok
[INFO] [stdout] test provider::registry::tests::test_build_endpoint_url_anthropic ... ok
[INFO] [stdout] test cli::model_fetcher::tests::test_generate_display_name ... ok
[INFO] [stdout] test config::tests::test_config_serialization_deserialization ... ok
[INFO] [stdout] test lib_tests::test_config_module_exports ... ok
[INFO] [stdout] test cli::openclaw_export::tests::test_openclaw_merge_rejects_malformed_json ... ok
[INFO] [stdout] test middleware::auth::tests::test_constant_time_comparison ... ok
[INFO] [stdout] test proxy::client::tests::test_https_enforcement_blocks_http_with_key ... ok
[INFO] [stdout] test lib_tests::test_module_structure ... ok
[INFO] [stdout] test proxy::client::tests::test_internal_ip_blocks_private ... ok
[INFO] [stdout] test proxy::client::tests::test_internal_ip_blocks_cgn ... ok
[INFO] [stdout] test proxy::client::tests::test_internal_ip_ipv4_mapped ... ok
[INFO] [stdout] test proxy::client::tests::test_internal_ip_ipv6_loopback ... ok
[INFO] [stdout] test provider::registry::tests::test_registry_creation ... ok
[INFO] [stdout] test provider::registry::tests::test_all_models ... ok
[INFO] [stdout] test proxy::client::tests::test_internal_ip_strict_allows_cgn ... ok
[INFO] [stdout] test proxy::client::tests::test_internal_ip_allows_public ... ok
[INFO] [stdout] test config::tests::test_config_with_custom_values ... ok
[INFO] [stdout] test provider::registry::tests::test_update_from_discovery ... ok
[INFO] [stdout] test cli::openclaw_export::tests::test_openclaw_merge_rejects_non_object_json ... ok
[INFO] [stdout] test provider::registry::tests::test_disabled_provider_not_included ... ok
[INFO] [stdout] test provider::registry::tests::test_model_to_provider_mapping ... ok
[INFO] [stdout] test proxy::client::tests::test_metadata_endpoint_rejects_subdomains ... ok
[INFO] [stdout] test proxy::client::tests::test_metadata_endpoint_exact_match ... ok
[INFO] [stdout] test proxy::client::tests::test_internal_ip_strict_blocks_private ... ok
[INFO] [stdout] test proxy::client::tests::test_https_enforcement_localhost ... ok
[INFO] [stdout] test http_client::tests::test_shared_client_is_created ... ok
[INFO] [stdout] test http_client::tests::test_create_custom_client ... ok
[INFO] [stdout] test proxy::client::tests::test_https_enforcement_127_ip ... ok
[INFO] [stdout] test config::tests::test_config_with_providers ... ok
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/aperture_router-cd8997b4daf02299)
[INFO] [stdout] test config::tests::test_config_toml_roundtrip ... ok
[INFO] [stderr]      Running tests/auth_tests.rs (/opt/rustwide/target/debug/deps/auth_tests-77461f23a943d799)
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 58 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.05s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 22 tests
[INFO] [stdout] test auth_tests::test_auth_state_is_enabled_with_keys ... ok
[INFO] [stdout] test auth_tests::test_auth_state_durations ... ok
[INFO] [stdout] test auth_tests::test_admin_key_not_accessible_when_empty ... ok
[INFO] [stdout] test auth_tests::test_auth_state_is_enabled_no_keys ... ok
[INFO] [stdout] test auth_tests::test_auth_state_with_custom_limits ... ok
[INFO] [stdout] test auth_tests::test_auth_state_trusted_proxies ... ok
[INFO] [stdout] test auth_tests::test_check_and_record_failure_different_ips ... ok
[INFO] [stdout] test auth_tests::test_multiple_ips_independent_tracking ... ok
[INFO] [stdout] test auth_tests::test_record_success_clears_failures ... ok
[INFO] [stdout] test auth_tests::test_validate_admin_key_constant_time ... ok
[INFO] [stdout] test auth_tests::test_validate_admin_key_invalid ... ok
[INFO] [stdout] test auth_tests::test_is_admin_enabled ... ok
[INFO] [stdout] test auth_tests::test_check_and_record_failure_exceeds_limit ... ok
[INFO] [stdout] test auth_tests::test_validate_admin_key_valid ... ok
[INFO] [stdout] test auth_tests::test_validate_api_key_constant_time ... ok
[INFO] [stdout] test auth_tests::test_validate_api_key_invalid ... ok
[INFO] [stdout] test auth_tests::test_validate_admin_key_multiple_keys ... ok
[INFO] [stdout] test auth_tests::test_validate_admin_key_vs_regular_key ... ok
[INFO] [stdout] test auth_tests::test_check_and_record_failure_within_limits ... ok
[INFO] [stdout] test auth_tests::test_validate_api_key_multiple_keys ... ok
[INFO] [stderr]      Running tests/config_tests.rs (/opt/rustwide/target/debug/deps/config_tests-2335a1b5a36c7cd2)
[INFO] [stdout] test auth_tests::test_validate_api_key_valid ... ok
[INFO] [stdout] test auth_tests::test_auth_state_cleanup_task_creation ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 22 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.15s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 36 tests
[INFO] [stdout] test config_tests::test_aperture_config_default ... ok
[INFO] [stdout] test config_tests::test_config_default_values ... ok
[INFO] [stdout] test config_tests::test_config_server_addr_invalid ... ok
[INFO] [stdout] test config_tests::test_config_validation_ban_duration_zero ... ok
[INFO] [stdout] test config_tests::test_config_validation_auth_window_zero ... ok
[INFO] [stdout] test config_tests::test_config_validation_health_rate_limit_zero_rps ... ok
[INFO] [stdout] test config_tests::test_config_validation_empty_api_key ... ok
[INFO] [stdout] test config_tests::test_config_validation_api_key_insufficient_entropy ... ok
[INFO] [stdout] test config_tests::test_config_validation_empty_base_url ... ok
[INFO] [stdout] test config_tests::test_config_server_addr ... ok
[INFO] [stdout] test config_tests::test_config_validation_api_key_too_short ... ok
[INFO] [stdout] test config_tests::test_config_validation_max_auth_attempts_zero ... ok
[INFO] [stdout] test config_tests::test_config_validation_max_body_size_too_large ... ok
[INFO] [stdout] test config_tests::test_config_load_invalid_file ... ok
[INFO] [stdout] test config_tests::test_config_validation_health_rate_limit_zero_burst ... ok
[INFO] [stdout] test config_tests::test_config_validation_placeholder_api_key ... ok
[INFO] [stdout] test config_tests::test_config_load_invalid_toml ... ok
[INFO] [stdout] test config_save_tests::test_config_save_creates_with_secure_permissions ... ok
[INFO] [stdout] test config_save_tests::test_config_save_file_permissions ... ok
[INFO] [stdout] test config_save_tests::test_config_save_atomic_write ... ok
[INFO] [stdout] test config_tests::test_config_load_from_file ... ok
[INFO] [stdout] test config_tests::test_security_config_default ... ok
[INFO] [stdout] test config_tests::test_trusted_proxies ... ok
[INFO] [stdout] test config_tests::test_config_validation_placeholder_security_key ... ok
[INFO] [stdout] test config_tests::test_config_validation_port_zero ... ok
[INFO] [stdout] test config_tests::test_config_validation_rate_limit_zero_burst ... ok
[INFO] [stdout] test config_tests::test_config_validation_rate_limit_zero_rps ... ok
[INFO] [stdout] test config_tests::test_config_validation_max_body_size_zero ... ok
[INFO] [stdout] test config_save_tests::test_config_save_overwrites_existing ... ok
[INFO] [stdout] test config_tests::test_config_validation_valid_api_key_entropy ... ok
[INFO] [stdout] test config_tests::test_config_validation_valid_config ... ok
[INFO] [stdout] test config_tests::test_cors_config_default ... ok
[INFO] [stdout] test config_tests::test_http_config_default ... ok
[INFO] [stdout] test config_tests::test_rate_limit_config_default ... ok
[INFO] [stdout] test config_tests::test_model_aliases ... ok
[INFO] [stdout] test config_save_tests::test_config_save_preserves_secrets ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 36 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.04s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/integration_tests.rs (/opt/rustwide/target/debug/deps/integration_tests-3e50e89bd2740fbe)
[INFO] [stdout] 
[INFO] [stdout] running 14 tests
[INFO] [stdout] test integration_tests::test_authentication_with_invalid_key ... ok
[INFO] [stdout] test integration_tests::test_error_handling_invalid_json ... ok
[INFO] [stdout] test integration_tests::test_authentication_required_endpoint ... ok
[INFO] [stdout] test integration_tests::test_cors_preflight_request ... ok
[INFO] [stdout] test integration_tests::test_full_health_check_flow ... ok
[INFO] [stdout] test integration_tests::test_concurrent_requests_handling ... ok
[INFO] [stdout] test integration_tests::test_rate_limiting_on_failed_auth ... ok
[INFO] [stdout] test integration_tests::test_security_headers ... ok
[INFO] [stdout] test integration_tests::test_streaming_endpoint_requires_stream_flag ... ok
[INFO] [stderr]      Running tests/proxy_tests.rs (/opt/rustwide/target/debug/deps/proxy_tests-c9a53a967f36577f)
[INFO] [stdout] test integration_tests::test_authentication_with_x_api_key_header ... ok
[INFO] [stdout] test integration_tests::test_no_auth_when_disabled ... ok
[INFO] [stdout] test integration_tests::test_authentication_with_valid_key ... ok
[INFO] [stdout] test integration_tests::test_anthropic_endpoint_with_auth ... ok
[INFO] [stdout] test integration_tests::test_streaming_endpoint_with_auth ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 14 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.04s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 11 tests
[INFO] [stdout] test proxy_tests::test_proxy_client_base_url ... ok
[INFO] [stdout] test proxy_tests::test_proxy_client_creation_no_api_key ... ok
[INFO] [stdout] test proxy_tests::test_proxy_client_custom_timeouts ... ok
[INFO] [stdout] test proxy_tests::test_proxy_client_forward_request_bad_gateway ... ok
[INFO] [stdout] test proxy_tests::test_proxy_client_connection_error ... ok
[INFO] [stdout] test proxy_tests::test_proxy_client_forward_request_with_api_key ... ok
[INFO] [stdout] test proxy_tests::test_proxy_client_forward_request_rate_limit ... ok
[INFO] [stdout] test proxy_tests::test_proxy_client_forward_request_success ... ok
[INFO] [stdout] test proxy_tests::test_proxy_client_forward_request_server_error ... ok
[INFO] [stderr]      Running tests/route_tests.rs (/opt/rustwide/target/debug/deps/route_tests-17bb5322927c3e79)
[INFO] [stdout] test proxy_tests::test_proxy_client_creation ... ok
[INFO] [stdout] test proxy_tests::test_proxy_client_invalid_endpoint ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 11 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.03s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 19 tests
[INFO] [stdout] test route_tests::test_admin_stats_with_invalid_admin_key ... ok
[INFO] [stdout] test route_tests::test_admin_stats_without_auth_header ... ok
[INFO] [stdout] test route_tests::test_cors_headers ... ok
[INFO] [stdout] test route_tests::test_admin_stats_with_valid_admin_key ... ok
[INFO] [stdout] test route_tests::test_admin_no_keys_configured_returns_401 ... ok
[INFO] [stdout] test route_tests::test_compression_layer ... ok
[INFO] [stdout] test route_tests::test_admin_refresh_models_without_key ... ok
[INFO] [stdout] test route_tests::test_admin_stats_with_x_api_key_header ... ok
[INFO] [stdout] test route_tests::test_admin_stats_with_regular_key_fails ... ok
[INFO] [stdout] test route_tests::test_health_response_format ... ok
[INFO] [stdout] test route_tests::test_not_found_endpoint ... ok
[INFO] [stdout] test route_tests::test_router_with_custom_config ... ok
[INFO] [stdout] test route_tests::test_health_endpoint ... ok
[INFO] [stdout] test route_tests::test_health_endpoint_options ... ok
[INFO] [stdout] test route_tests::test_router_creation ... ok
[INFO] [stdout] test route_tests::test_trace_layer_present ... ok
[INFO] [stdout] test route_tests::test_router_with_auth_enabled ... ok
[INFO] [stdout] test route_tests::test_admin_refresh_models_with_valid_key ... ok
[INFO] [stdout] test route_tests::test_multiple_health_requests ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 19 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.02s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/type_tests.rs (/opt/rustwide/target/debug/deps/type_tests-95b8f5ded6a5fd99)
[INFO] [stdout] 
[INFO] [stdout] running 13 tests
[INFO] [stdout] test type_tests::test_anthropic_message_request_minimal ... ok
[INFO] [stdout] test type_tests::test_anthropic_message_request_deserialization ... ok
[INFO] [stderr]      Running tests/validation_tests.rs (/opt/rustwide/target/debug/deps/validation_tests-08ce4415009a0d59)
[INFO] [stdout] test type_tests::test_chat_completion_request_deserialization ... ok
[INFO] [stdout] test type_tests::test_chat_completion_request_edge_cases ... ok
[INFO] [stdout] test type_tests::test_chat_completion_request_large_values ... ok
[INFO] [stdout] test type_tests::test_anthropic_message_request_serialization ... ok
[INFO] [stdout] test type_tests::test_chat_completion_request_minimal ... ok
[INFO] [stdout] test type_tests::test_chat_completion_request_with_multiple_messages ... ok
[INFO] [stdout] test type_tests::test_chat_completion_request_serialization ... ok
[INFO] [stdout] test type_tests::test_missing_required_field ... ok
[INFO] [stdout] test type_tests::test_invalid_json_handling ... ok
[INFO] [stdout] test type_tests::test_tool_calls_in_message ... ok
[INFO] [stdout] test type_tests::test_serialization_preserves_model_name ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 13 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 15 tests
[INFO] [stderr]    Doc-tests aperture_router
[INFO] [stdout] test test_validate_message_content_empty ... ok
[INFO] [stdout] test test_validate_model_name_injection_attempts ... ok
[INFO] [stdout] test test_validate_message_content_boundary ... ok
[INFO] [stdout] test test_validate_model_name_empty ... ok
[INFO] [stdout] test test_validate_message_content_valid ... ok
[INFO] [stdout] test test_validate_model_name_max_length ... ok
[INFO] [stdout] test test_validate_model_name_path_traversal ... ok
[INFO] [stdout] test test_validate_message_content_too_long ... ok
[INFO] [stdout] test test_validate_model_name_spaces ... ok
[INFO] [stdout] test test_validate_model_name_special_chars ... ok
[INFO] [stdout] test test_validate_model_name_too_long ... ok
[INFO] [stdout] test test_validate_model_name_unicode ... ok
[INFO] [stdout] test test_validate_model_name_valid ... ok
[INFO] [stdout] test test_validate_role_invalid ... ok
[INFO] [stdout] test test_validate_role_valid ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 15 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "7c60510b637b26f35e4f54daa872af53c07a4a6318fb8b091a3ded5be9f6cdb9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7c60510b637b26f35e4f54daa872af53c07a4a6318fb8b091a3ded5be9f6cdb9", kill_on_drop: false }`
[INFO] [stdout] 7c60510b637b26f35e4f54daa872af53c07a4a6318fb8b091a3ded5be9f6cdb9
